var Utils = {
	alert : function(content, title) {
		var frameAlert=$('<div id="frameAlert" style="display:none;"></div>');
		frameAlert.html('<p>'+content+'</p>');
		if($("#frameAlert").length==0){
			$("#WidgetContainer").append(frameAlert);
			$("#frameAlert").dialog({
				width : 400,
				autoOpen : true,
				modal : true,
				position : ['center'],
				buttons : {
					'确定' : function() {
						$(this).dialog("close");
					}
				}
			});
			$("#frameAlert").parent().find('.ui-dialog-title').html(title);
			$("#frameAlert").show();
		}else{
			$("#frameAlert").dialog('open');
		}
	},
	
	
	//地图测量弹出窗体
	measureAlert : function(content, title){
		var measure=$('<div id="measure"></div>');
		measure.css({
			'height' : '0px',
			'display' : 'none',
			'font-size' :'12px'
		});
		if($("#measure").length==0){
			measure.html('<p>'+content+'</p>');
			$("#WidgetContainer").append(measure);
			$("#measure").dialog({
				width : 205,
				autoOpen : true,
				modal : true,
				position : ['center'],
				buttons : {
				}
			});
			$("#measure").parent().find('.ui-dialog-title').css({
				'font-size' :'12px'
			}).html(title);
			$("#measure").show();
		}else{
			$("#measure").html('<p>'+content+'</p>');
			$("#measure").parent().find('.ui-dialog-title').html(title);
			$("#measure").dialog('open');
			$("#measure").show();
		}
	}
};

/**
 *
 *字符串替换
 *
 */
String.prototype.replaceAll = function(s1,s2) { 
    return this.replace(new RegExp(s1,"gm"),s2); 
}




/**
 *Array.prototype.remove = function(s) {
 *	for (var i = 0; i < this.length; i++) {
 *		if (s == this[i])
 *			this.splice(i, 1);
 *	}
 *}
*/
/**
 * Simple Map
 * 
 * 
 * var m = new Map();
 * m.put('key','value');
 * ...
 * var s = "";
 * m.each(function(key,value,index){
 * 		s += index+":"+ key+"="+value+"\n";
 * });
 * alert(s);
 * 
 * @author dewitt
 * @date 2008-05-24
 */
function Map() {
	/** 存放键的数组(遍历用到) */
	this.keys = new Array();
	/** 存放数据 */
	this.data = new Object();
	
	/**
	 * 放入一个键值对
	 * @param {String} key
	 * @param {Object} value
	 */
	this.put = function(key, value) {
		if(this.data[key] == null){
			this.keys.push(key);
		}
		this.data[key] = value;
	};
	
	/**
	 * 获取某键对应的值
	 * @param {String} key
	 * @return {Object} value
	 */
	this.get = function(key) {
		return this.data[key];
	};
	
	/**
	 * 删除一个键值对
	 * @param {String} key
	 */
	//this.remove = function(key) {
	//	this.keys.remove(key);
	//	this.data[key] = null;
	//};
	
	/**
	 * 遍历Map,执行处理函数
	 * 
	 * @param {Function} 回调函数 function(key,value,index){..}
	 */
	this.each = function(fn){
		if(typeof fn != 'function'){
			return;
		}
		var len = this.keys.length;
		for(var i=0;i<len;i++){
			var k = this.keys[i];
			fn(k,this.data[k],i);
		}
	};
	
	/**
	 * 获取键值数组(类似Java的entrySet())
	 * @return 键值对象{key,value}的数组
	 */
	this.entrys = function() {
		var len = this.keys.length;
		var entrys = new Array(len);
		for (var i = 0; i < len; i++) {
			entrys[i] = {
				key : this.keys[i],
				value : this.data[i]
			};
		}
		return entrys;
	};
	
	/**
	 * 判断Map是否为空
	 */
	this.isEmpty = function() {
		return this.keys.length == 0;
	};
	
	/**
	 * 获取键值对数量
	 */
	this.size = function(){
		return this.keys.length;
	};
	
	/**
	 * 重写toString 
	 */
	this.toString = function(){
		var s = "{";
		for(var i=0;i<this.keys.length;i++,s+=','){
			var k = this.keys[i];
			s += k+"="+this.data[k];
		}
		s+="}";
		return s;
	};
}

